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(57) The present invention relates to methods and 
apparatus for performing generational garbage collec- 
tion within computer memory. According to one aspect 
of the present invention, a computer-implemented 
method for dynamically managing memory which in- 
cludes a first memory section and a second memory 
section that is divided into a plurality of blocks each hav- 
ing an associated marker, includes performing a first 
garbage collection on the first memory section. The 
method also includes performing a second garbage col- 
lection on a selected one of the blocks in the second 
memory section. A third garbage collection is performed 



on the selected block in the second memory section. 
The third garbage collection includes determining 
whether the selected block includes a first object which 
references a second object which is not included in the 
selected block based at least in part on a status indicat- 
ed by the marker associated with the selected block. 
The status includes an indication of whether the refer- 
ence to the second object was stored after the second 
garbage collection was performed, and if the reference 
to the second object was stored after the second gar- 
bage collection was performed, a new root array is cre- 
ated using the selected marker. 
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Description 

BACKGROUND OF THE INVENTION 

1. Field of Invention 

[0001] The invention relates generally to the manage- 
ment of dynamically allocated memory in a computer 
system. More particularly, the invention relates to track- 
ing references between separate sections of memory 
associated with a computer system such that automatic 
storage-reclamation may be performed locally. 

2. Description of the Relevant Art 

[0002] The amount of memory associated with a com- 
puter system is typically limited. As such, memory must 
generally be conserved and recycled. Many computer 
programming languages enable software developers to 
dynamically allocate memory within a computer system. 
Some programming languages require explicit manual 
deallocation of previously allocated memory, which may 
be complicated and prone to error. Languages which re- 
quire explicit manual memory management include the 
C and C++ programming languages. Other program- 
ming languages utilize automatic storage-reclamation 
to reclaim memory that is no longer necessary to ensure 
the proper operation of computer programs which allo- 
cate memory from the reclamation system. Such auto- 
matic storage-reclamation systems reclaim memory 
without explicit instructions or calls from computer pro- 
grams which were previously utilizing the memory. 
[0003] In object-oriented or object-based systems, 
the typical unit of memory allocation is commonly re- 
ferred to as an object or a memory object, as will be ap- 
preciated by those skilled in the art. Objects which are 
in use are generally referred to as " live" objects, where- 
as objects which are no longer needed to correctly ex- 
ecute computer programs are typically referred to a " 
garbage" objects. The act of reclaiming garbage objects 
is commonly referred to as garbage collection, while an 
automatic storage-reclamation system is often referred 
to as a garbage collector. Computer programs which 
use automatic storage-reclamation systems are known 
as mutators due to the fact that such computer programs 
can change live memory objects during execution. Com- 
puter programs written in languages such as the Java™ 
programming language (developed by Sun Microsys- 
tems, Inc. of Palo Alto, California) and the Smalltalk pro- 
gramming language use garbage collection to automat- 
ically manage memory. 

[0004] Objects typically contain references to other 
objects. As such, an area of computer memory which is 
managed by a garbage collector will generally contain 
a set of objects which reference one another. Figure 1 
is a diagrammatic representation of an area of computer 
memory which contains objects. A managed area of 
memory 10, which is typically a heap associated with a 



computer system, includes objects 20. In general, an 
object 20 may be referenced by other objects 20. By way 
of example, object 20a has a pointer 24a to object 20b. 
Object 20c also has a pointer 24b to object 20b. As such, 
5 object 20b is referenced by both objects 20a and 20c. 
[0005] A number of external references into memory 
1 0. As shown, a fixed root 30 which is external to mem- 
ory 10 includes pointers 34 to objects, e.g., objects 20a 
and 20c, located in memory 10. All objects, as for ex- 
ample objects 20a-d, which may be reachable by follow- 
ing references from fixed root 30 are considered to be 
live objects. Alternatively, object 20e, which is not reach- 
able by following references from fixed root 30, is char- 
acterized as a garbage object. 
[0006] Garbage collectors are typically implemented 
to identify garbage objects such as object 20e. In gen- 
eral, garbage collectors may operate using a number of 
different algorithms. Conventional garbage collection al- 
gorithms include reference counting collectors, mark 
sweep collectors, and copying collectors. As will be ap- 
preciated by those skilled in the art, during garbage col- 
lection, when objects 20 are moved, references to ob- 
jects 20 must be adjusted accordingly. 
[0007] It is often beneficial to separate a managed 
memory area into smaller sections to enable garbage 
collection to be performed locally in one area at a time. 
One memory partitioning scheme is generational gar- 
bage collection, in which objects are separated based 
upon their lifetimes as measured from the time the ob- 
jects were created. ■Younger" objects have been ob- 
served as being more likely to become garbage than " 
older" objects. As such, generational garbage collection 
may be used to increase the overall efficiency of mem- 
ory reclamation. 

[0008] Figure 2 is a diagrammatic representation of 
an interface between a root and memory which is parti- 
tioned into a new generation and an old generation. A 
memory 110, which is typically a heap that is associated 
with a computer system, includes a new generation 
110a and an old generation 110b. A fixed root 114, or a 
global object which references objects within either or 
both new generation 110a and old generation 110b, in- 
cludes pointers 116 to objects 120 in new generation 
110a, as shown. Root 114 may be located on a stack, 
as will be appreciated by those skilled in the art. 
[0009] Some objects 120 within new generation 110a, 
as for example object 1 20a, may also be considered as 
roots, since object 120a is assumed to be live and in- 
cludes a pointer 122 to another object 120d. When new 
generation object 1 26 is live and points to old generation 
object 128, garbage collection performed in old gener- 
ation 1 1 0b does not generally "collect" object 1 28. How- 
ever, if new generation object 1 26 is dead, a garbage 
collection performed in new generation 110a will result 
in old generation object 128 becoming unreachable, 
since old generation object 1 28 will not be pointed to by 
any other object. If old generation object 1 28 is unreach- 
able, then garbage collection performed in old genera- 
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tion 110b will result in the collection of old generation 
object 128. It should be appreciated that pointer 130, 
which points between new generation object 126 and 
old generation object 128 is considered to be an inter- 
generational pointer, since pointer 130 spans both new 
generation 110a and old generation 110b. When pointer 
1 30 points from new generation object 126 to old gen- 
eration object 128, old generation object 128 is consid- 
ered to be tenured garbage, as old generation object 
1 28 is not collectable using new generation garbage col- 
lection. 

[0010] Another memory partitioning scheme involves 
separating memory into smaller areas in order to reduce 
the amount of time required for a single garbage collec- 
tion to be performed.. Pauses caused by garbage col- 
lection often tend to disrupt an associated mutator and 
are, therefore, undesirable. In some systems, the gar- 
bage collector may be able to provide a guaranteed 
small maximum pause duration. Such garbage collec- 
tors associated are known as real-time garbage collec- 
tors. In other systems, the garbage collector may at- 
tempt to keep pause times small, but may fail to do so 
in some situations. Garbage collectors which attempt to 
keep pause times small are known as non-disruptive or 
incremental garbage collectors. 
[001 1 ] In order to operate on an individual memory ar- 
ea, a garbage collector must have knowledge of all ref- 
erences into that area. References into an area are re- 
ferred to as roots for that area. It should be appreciated 
that roots may include both external references, e.g., 
fixed roots, and references from other areas of computer 
memory. Accordingly, garbage collectors generally pro- 
vide mechanisms for finding and tracking roots, or ref- 
erences. 

[001 2] One method of locating references into a mem- 
ory area involves scanning through all objects in mem- 
ory. For most systems, scanning through all objects in 
memory is prohibitively time-consuming. As such, a 
more elaborate tracking scheme is often required. 
[001 3] Whenever a mutator stores a reference into an 
object, additional processing may be implemented in or- 
der to track references for garbage collection purposes. 
This additional processing is known as a write barrier or 
store check. In order for efficiency of the mutator to be 
maintained at an acceptable level, the costs associated 
with the write barrier must be kept as low as possible. 
[001 4] One way of tracking references into a memory 
area involves maintaining a set which holds all roots for 
the area. Such a set is generally known as a remem- 
bered set for the area. The associated write barrier will 
detect when a reference into an area is stored. Accord- 
ingly, the write barrier will insert the location of the ref- 
erence into the remembered set associated with the ar- 
ea. 

[0015] Figure 3 is a diagrammatic representation of 
pointers between objects in a new generation and ob- 
jects in an old generation which are tracked using a re- 
membered set. A memory 302 is divided into a new gen- 



eration 302a and an old generation 302b. A remem- 
bered set 304 is used to track pointers 314 which point 
from old generation objects 310 to new generation ob- 
jects 312. The address of old generation object 310a is 

5 stored in remembered set 304, as old generation object 
310a includes pointer 314a to new generation object 
312b. Similarly, the. address of old generation object 
310b, which includes pointers 314b and 314c to new 
generation objects 312b and 312a, respectively, is also 

10 stored in remembered set 304. 

[0016] Locating roots for garbage collection is 
straightforward when a remembered set is used, since 
the remembered set will contain all of the roots. Howev- 
er, the use of a write barrier is often expensive, as ex- 

15 cess memory may be required. Also, when a new loca- 
tion is to be inserted into a remembered set, it is possible 
that the particular location may already be present within 
the remembered set. Checking the remembered set for 
duplicate locations prior to inserting a location is expen- 

20 sive. On the other hand, eliminating a check for dupli- 
cate locations may cause the remembered set to grow 
unnecessarily large. As will be appreciated by those 
skilled in the art, there is generally no upper bound on 
the number of duplicates which a remembered set may 

2S hold. When a reference to a location is to be stored, the 
location often already contains a previous reference. As 
a result, a remembered set entry that is associated with 
the location prior to a storage operation will generally 
become invalid following the storage operation. Remov- 

30 ing an old entry may prove to be a costly operation in 
some situations, whereas leaving an old entry in place 
may result in the occupation of excess memory by a re- 
membered set. 

[0017] Another scheme which is often used for track- 

35 jng references into a memory area is known as card 
marking. In general, card marking involves conceptually 
dividing memory into relatively small parts called cards. 
A garbage collector will then allocate an array of bits 
with one entry.per card. When a reference is stored, the 

40 write barrier will compute the corresponding card array 
entry and set the associated bit. This process is known 
as n dirtying" the card. It should be appreciated that for 
efficiency reasons, a byte or a word array are often used 
in lieu of a bit array. 

4$ [0018] One advantage of using card marking is that 
the write barrier is relatively cheap. Another advantage 
of using card marking is that the amount of memory re- 
quired for the card array is fixed. However, the process- 
ing required for locating roots at garbage collection time 

so js often significant, e.g., more processing is required 
than would be for a system which utilizes a remembered 
set. The garbage collector only knows approximately 
where reference stores have occurred. That is, the gar- 
bage collector only knows where the card marking array 

55 has dirty entries. Once a dirty entry is identified, the cor- 
responding cards must be scanned for roots. Although 
scanning a card for roots is generally much cheaper 
than scanning an entire memory, scanning the card is 
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still often costly. As will be understood by those skilled 
in the art, when a garbage collector locates a root, the 
corresponding card array entry must be kept dirty in or- 
der for the root to be located the next time garbage col- 
lection is invoked. s 
[0019] A combined scheme may use remembered 
sets and card marking. A write barrier will perform card 
marking as described above. However, at garbage col- 
lection time, the garbage collector will construct remem- 
bered sets for each card. When garbage collection is 
completed, the card marking array may then be cleared. 
Using a combined remembered set and card marking 
scheme reduces the amount of scanning required for 
subsequent garbage collections, thereby increasing the 
overall efficiency of garbage collection processes. How- 
ever, the implementation of such schemes is often com- 
plicated. Therefore, what is desired is a method and an 
apparatus for efficiently implementing a combined re- 
membered set and card marking scheme. 

SUMMARY OF THE INVENTION 

[0020] The present invention relates to methods and 
apparatus for performing generational garbage collec- 
tion within computer memory. According to one aspect 
of the present invention, a computer-implemented 
method for dynamically managing memory which in- 
cludes a first memory section and a second memory 
section that is divided into a plurality of blocks each hav- 
ing an associated marker, includes performing a first 
garbage collection on the first memory section. The 
method also includes performing a second garbage col- 
lection on a selected one of the blocks in the second 
memory section. A third garbage collection is performed 
on the selected block in the second memory section. 
The third garbage collection includes determining 
whether the selected block includes a first object which 
references a second object which is not included in the 
selected block based at least in part on a status indicat- 
ed by the marker associated with the selected block: 
The status includes an indication of whether the refer- 
ence to the second object was stored after the second 
garbage collection was performed, and if the reference 
to the second object was stored after the second gar- 
bage collection was performed, a new root array is cre- 
ated using the selected marker. 
[0021] In accordance with another aspect of the 
present invention, a computer-implemented method for 
allocating a selected object in computer memory in- 
volves determining whether a first section of the memory 
is suitable for the selected object to be allocated, and 
allocating the selected object when it is determined that 
the first section is suitable for the object to be allocated. 
The method also involves performing a garbage collec- 
tion in the first section when it is determined that the first 
section is not suitable for the selected object to be allo- 
cated. Performing the garbage collection in the first sec- 
tion includes scanning an array of words to locate a se- 



lected word that is arranged to indicate that a first root 
associated with the word references an object which al- 
ready exists in the memory. 

[0022] In accordance with still another aspect of the 
present invention, a computer system includes a mem- 
ory arranged as a first memory section and a second 
memory section, where the second memory section is 
divided into a plurality of blocks. Such a computer sys- 
tem also includes a processor that is coupled to the 
memory, and a first garbage collector which is associat- 
ed with the first memory section. A second garbage col- 
lector associated with the second memory section is ar- 
ranged to perform a garbage collection on a selected 
block which has an associated marker that is arranged 
to indicate whether the selected block includes a first 
object which references a second object that is not in- 
cluded in the selected block. The selected markers is 
associated with a root arrays which hold address of the 
object when the object references the second object that 
is not in the selected block. In one embodiment, the sec- 
ond garbage collector is arranged to use the marker to 
identify whether the second object is in the first memory 
section. 

[0023] These and other advantages of the present in- 
vention will become apparent upon reading the following 
detailed descriptions and studying the various figures of 
the drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0024] The invention, together with further advantag- 
es thereof, may best be understood by reference to the 
following description taken in conjunction with the ac- 
companying drawings in which: 
[0025] Figure 1 is a diagrammatic representation of 
an area of computer memory which contains objects in 
accordance with prior art. 

[0026] Figure 2 is a diagrammatic representation of 
an interface between a root and memory which includes 
a new generation and an old generation in accordance 
with prior art. 

[0027] Figure 3 is a diagrammatic representation of a 
memory which is associated with a remembered set in 
accordance with prior art. 

[0028] Figure 4a is a diagrammatic representation of 
an old generation memory which is segmented into 
trains in accordance with an embodiment of the present 
invention. 

[0029] Figure 4b is a diagrammatic representation of 
an array of card marks and an associated pool of root 
arrays in accordance with an embodiment of the present 
invention. 

[0030] Figure 5 is a process flow diagram which illus- 
trates the steps associated with executing a computer 
program in accordance with an embodiment of the 
present invention. 

[0031] Figure 6 is a process flow diagram which illus- 
trates a process of performing a garbage collection, /. 
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a, step 510 of Figure 5, in accordance with an embod- 
iment of the present invention. 
[0032] Figure 7a is a process flow diagram which il- 
lustrates the steps associated with a garbage collection 
in new generation memory, i.e., step 604 of Figure 6, in 
accordance with an embodiment of the present inven- 
tion. 

[0033] Figure 7b is a process flow diagram which il- 
lustrates the steps associated with following a single 
root in accordance with an embodiment of the present 
invention. 

[0034] Figures 7c-7e are a process flow diagram 
which illustrates the steps associated with updating a 
card mark, i.e., step 728 of Figure 7b, in accordance 
with an embodiment of the present invention. 
[0035] Figures 8a and 8b are a process flow diagram 
which illustrates the steps associated with performing 
an old generation garbage collection, i.e., step 608 of 
Figure 6, in accordance with an embodiment of the 
present invention. 

[0036] Figure 9 is a diagrammatic representation of a 
computer system suitable for implementing the present 
invention. 

DETAILED DESCRIPTION OF THE EMBODIMENTS 

[0037] Garbage collection is used to dynamically al- 
locate computer memory for use by a computer pro- 
gram. In general, garbage collection causes pauses in 
the execution of the program. One apparatus for reduc- 
ing the pause-times associated with garbage collection 
is to divide the memory into a plurality of generations. 
By way of example, in a two generation memory struc- 
ture, the memory may be divided into a new generation, 
which includes newly allocated objects, and an old gen- 
eration, which includes older objects. It should be ap- 
preciated that, newly allocated objects tend to die more 
quickly than older objects. As such, garbage collection 
may be performed more often in the new generation 
than in the old generation. Typically, the new generation 
is relatively small compared to the overall size of the 
memory. 

[0038] Accordingly, garbage collection within the new 
generation may typically be performed without causing 
substantial interruptions during the execution of a pro- 
gram. 

[0039] While garbage collection in the new generation 
may not result in significant pause-times, garbage col- 
lection in the old generation may still cause significant 
pauses during the execution of a program, since the old 
generation is typically larger than the new generation. 
Further, if inter-generational pointers from objects in the 
old generation to objects in the new generation exist, 
then the inter-generational pointers are often tracked 
while a program executes. The inter-generational point- 
ers are tracked since objects in the old generation that 
are associated with such pointers are considered to be 
roots of the new generation . The tracking of the pointers, 



or references, from objects in the old generation to ob- 
jects in the new generation is often complicated and, 
therefore, time-consuming. 

[0040] By dividing old generation memory into smaller 

5 areas, or blocks, pause-times associated with old gen- 
eration garbage collection may be reduced. Old gener- 
ation garbage collection may be performed in a specific 
block of old generation memory each time old genera- 
tion garbage collection is performed. By limiting the 

10 blocks in which old generation garbage collection is per- 
formed, and by collecting garbage in different blocks 
each time old generation garbage collection is per- 
formed, the efficiency of the old generation garbage col- 
lection may be enhanced. 

is [0041] As previously mentioned, old generation mem- 
ory is divided into blocks to facilitate old generation gar- 
bage collection. Each time old generation garbage col- 
lection is performed, the old generation garbage collec- 
tion is performed on any suitable block. That is, old gen- 

20 eration garbage collection may be performed incremen- 
tally. In one embodiment, garbage collection may be 
performed on the oldest block in which garbage collec- 
tion has not been performed. In another embodiment, 
garbage collection may be performed on the block in 

25 which garbage collection has been performed least re- 
cently. 

[0042] With reference to Figure 4a, the division of 
memory into blocks within an old generation will be de- 
scribed in accordance with an embodiment of the 

30 present invention. An old generation 404 includes 
blocks 408 of memory. The blocks of memory are typi- 
cally allocated on an as-needed basis. That is, addition- 
al blocks are allocated when substantially all existing 
blocks 408 are full. Blocks 408, which contain objects 

35 associated with a particular program, are often referred 
to as ■ cars." Blocks or cars 408 are arranged in linked 
sets which are known as "trains" 41 2. For example, train 
412a includes cars 408a, 408b, while train 412b in- 
cludes cars 408c, 408d, 408e, and train 412c includes 

40 cars 408f and 408g. 

[0043] Cars 408 within trains 412 are generally or- 
dered based upon when a particular car 408 was added 
to a particular train 41 2. For example, within train 41 2a, 
if car 408b is added to train 412a after car 408a, car 

45 408a is considered to be a lower car in the same train 
as car 408b. Similarly, trains 412 are generally also or- 
dered based upon when a particular train 41 2 is created. 
As shown, if train 412b is added to memory 404 after 
train 412c, then train 412c is a lower train with respect 

50 to train 412b and, therefore, cars 408c, 408d, 408e, 
within train 412b. 

[0044] An algorithm which uses trains 41 2 to perform 
garbage collection within old generation 404 typically 
collects a set number of cars 408 at a time. In the de- 
55 scribed embodiment, only a single car 408 is collected 
during each old generation garbage collection, although 
it should be appreciated that any suitable number of cars 
may be collected during each old generation garbage 
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collection. By collecting one car 408 at a time, the overall 
length of old generation garbage collection, and, there- 
fore, the pause-times associated with old generation 
garbage collection is essentially bounded. Hence, the 
lengthy pause-times that are typically associated with 
old generation garbage collection may be reduced by 
collecting only a set number of cars 408 during each old 
generation garbage collection. 
[0045] In general, in order to perform garbage collec- 
tion in cars 408, all pointers which either originate in, or 
access objects within, each car 408 in old generation 
memory are tracked. One method for tracking pointers 
will be described below with respect to Figure 4b. When 
a particular car 408 which is to be collected includes a 
live object, the object is copied into a train 412 which 
either points to or is pointed to by the object. Then, once 
the copy of the object is made, the 0 original" object is 
collected or reclaimed. In general, when a selected train 
41 2 no longer has pointers outside of itself, the selected 
train 412 may be eliminated, i.e., the memory allocated 
to the selected train 41 2 is freed. Similarly, when a se- 
lected car 408 no longer has pointers outside of itself, 
the selected car 408 may be eliminated. 
[0046] In the described embodiment, the size of cars 
408 within a given train 41 2 is fixed. That is, all cars 408 
may be of substantially of the same size. Therefore, 
since a single car 408 may not have enough space to 
accommodate linked objects, an object 416a in one car 
408, e.g., car 408f, may be linked to an object 416b in 
a second car 408, e.g., car 408g. During an old gener- 
ation garbage collection, objects 416a, 416b are likely 
to survive, since objects 41 6a, 41 6b are in separate cars 
408, and reference each other. As such, an old gener- 
ation garbage collection may not result in the collection 
of cars 408f , 408g. Hence, memory associated with cars 
408f, 408g will not generally be freed unless pointers 
between cars 408f, 408g within train 412c are tracked. 
[0047] In general, the length of trains 41 2, as well as 
the size of cars 408 may be widely varied. The size of 
cars 408 may depend on factors which include, but are 
not limited to, the size of old generation 404, the speed 
of the garbage collection algorithm, and the speed of the 
computer running the garbage collection algorithm. By 
way of example, car sizes on the order of approximately 
20 kilobytes of memory to approximately 100 kilobytes 
of memory work well in current systems. In the de- 
scribed embodiment, cars 408 include approximately 64 
kilobytes of memory. 

[0048] Cars 408 may generally be divided into cards 
420 which may be used to facilitate old generation gar- 
bage collection performed on cars 408, as will be de- 
scribed below with respect to Figure 4b. Cards 420, like 
cars 408, may take on any suitable size, although cards 
420 may often include approximately 100 to approxi- 
mately 1000 bytes. For example, for cars 408 which in- 
clude approximately 64 kilobytes of memory, cards 420 
may include approximately 512 bytes. 
[0049] The efficiency of tracking inter-generational 



pointers which point from old generation objects to new 
generation objects may be improved by providing stor- 
age, or markers, that are associated with the different 
areas within the old generation. In one embodiment, a 

5 marker is a word that may include a flag which is set to 
indicate whether an associated portion of a particular 
area includes a pointer into an object in the new gener- 
ation. The use of such words provides an efficient struc- 
ture which may be used to track inter-generational point- 

io ers from objects in the old generation to objects in the 
new generation. Although a marker is described as be- 
ing a word, it should be appreciated that a marker may 
be any suitable storage type, as for example bits, bytes, 
and the like. 

15 [0050] In order to track inter-generational pointers 
from objects associated with cards in old generation 
memory to objects in new generation memory, cards 
may be provided with n tracking structures." The tracking 
structures, or card marks, may be used to identify 

20 whether inter-generational pointers exist for a card, and 
also which objects within the card include the pointers. 
Figure 4b is a diagrammatic representation of an array 
of card marks and an associated pool of root arrays in 
accordance with an embodiment of the present inven- 
ts tion. A root array is generally a small array which con- 
tains root locations which are specified as offsets rela- 
tive to a card. In other words, a root array is essentially 
a small, remembered set. An array 450 of card marks 
452 includes pointers 456 to root arrays 460 contained 

30 jn a pool 464 of root arrays 460. Card marks 452 are 
generally associated with a car within a train. Specifical- 
ly, a car within a train may be divided into a number of 
cards that hold old generation objects. As such, a car 
within a train may be associated with many card marks 

35 452. A grouping of card marks 452, which may or may 
not include all card marks 452 associated with a car, is 
considered to be an array 450 of card marks 452. In the 
described embodiment, array 450 includes all card 
marks 452 associated with the old generation. 

40 [0051] In the described embodiment, a card mark 
452, as for example card mark 452a, is a 32-bit word, 
although it should be appreciated that card mark 452a 
may generally be a word of any suitable length. Alterna- 
tively, the data structure that constitutes the card mark 

45 may be divided into a number of components. Although 
the bits which make up card mark 452a may be assigned 
in any manner that is appropriate to a particular appli- 
cation, in one embodiment, the lowest bits, or least sig- 
nificant bits, of card mark 452a are used as flags which 

so essentially identify the M status," or overall condition, of 
card mark 452a. A lowest bit 468 of card mark 452a is 
a " dirty" flag. That is, lowest bit 468 is generally ar- 
ranged to indicate whether card mark 452a or, more 
specifically, a card (as shown in Figure 4a) associated 

55 with card mark 452a, is "dirty." Dirty cards are cards 
where pointers have been stored since the last garbage 
collection. Such pointers may include, but are not limited 
to, an inter-generational pointer which points from old 
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generation memory into new generation memory, a 
pointer to a lower train, and a pointer to a lower car in 
the same train that is associated with card mark 452a. 
When lowest bit 468 is set, i.a, when lowest bit 468 is 
set to ■O," the indication is that card mark 452a is dirty. 
[0052] A second lowest bit 470 of card mark 452a is 
a new generation flag, and is used to indicate whether 
card mark 452a includes an inter-generational pointer 
to a new generation. When second lowest bit 470 is set, 
/.a, set to "0", the indication is that card mark 452a in- 
cludes an inter-generational pointer to a new genera- 
tion. A third lowest bit 472 is a lower train flag in the 
described embodiment. The lower train flag is arranged 
to indicate whether card mark 452a has a pointer into a 
lower train. When the lower train flag, or third lowest bit 
472, is set, the indication is that card mark 452a includes 
a pointer into a lower train. A fourth lowest bit 474 is a 
same train flag that is arranged to indicate whether card 
mark 452a includes a pointer into a lower car in the same 
train. 

[0053] In the described embodiment, in order for card 
mark 452a to be considered clean, card mark 452a gen- 
erally may not include a pointer which points from an old 
generation to a new generation, a pointer into a lower 
train, or a pointer into a lower car of the same train. As 
such, lowest bit 468, second lowest bit 470, third lowest 
bit 472, and fourth lowest bit 474 all have values of "1 0 
in the event that card mark 452a is clean. In other words, 
the lowest four bits of card mark 452a are cleared when 
card mark 452a is clean. Therefore, as shown, card 
marks 452a, 452b are clean, whereas card mark 452c, 
which has a lowest bit that is set, is dirty. 
[0054] The remaining twenty-eight bits in card mark 
452a may all be allocated for use as a pointer that points 
to an associated root array 460 which essentially holds 
addresses of pointers associated with card mark 452a. 
Alternatively, as for example in the described embodi- 
ment, card mark 452a includes a 27-bit pointer 478 and 
a reserved bit 480. 27-bit pointer 478 identifies pointer 
456a which points from card mark 452a into root array 
460a. Root array 460a is often either made up of eight 
words or sixteen words, although the number of words 
in root array 460a may be widely varied. Root arrays 
460 are generally arranged to hold references to roots. 
By way of example, root array 460a holds roots associ- 
ated with card mark 450a and, hence, a card (as shown 
in Figure 4a) that is associated with card mark 450a. 
[0055] When a suitable root array 460 is full, then a 0 
root array overflow" is said to occur. When too many 
roots are to be stored in a given root array 460, the roots 
are no longer tracked. A root array overflow generally 
occurs when the volume of pointers to root arrays 460 
in pool 464 is excessive with respect to the root arrays 
460 available for allocation in pool 464. Asa result, when 
performing garbage collection, the pointers in with the 
card associated with the root array overflow are then 
typically searched to identify roots. When a root array 
overflow occurs, 27-bit pointer 478 is set to null. That is, 



the twenty-seven bits in 27-bit pointer 478 are set to "0." 
[0056] Reserved bit 480 may be used for any number 
of suitable purposes which may or may not be directly 
related to garbage collection processes. Suitable pur- 

s poses include, but are not limited to, using reserved bit 
480 to indicate the age of card mark 452a. It should be 
appreciated that additional reserved bits may also be 
included in card mark 452a by reducing the number of 
bits associated with the pointer in card mark 452a, e.g., 

10 27-bit pointer 478. 

[0057] Card marks are used in conjunction with a gar- 
bage collection process to track cards within a car which 
include inter-generational pointers to objects in a new 
generation. In one embodiment, during the execution of 

is a computer program, the card marks may be updated 
to enable the card marks to remain substantially current. 
Then, during a garbage collection, the card marks may 
be checked to identify cards with inter-generational 
pointers. 

20 [0058] When card marks are used to facilitate a gar- 
bage collection process during the execution of a com- 
puter program, the card marks are generally both 
searched and updated to identify objects referenced by 
the card marks. Referring next to Figure 5, the steps as- 

25 sociated with executing a program which uses garbage 
collection will be described in accordance with an em- 
bodiment of the present invention. Prior to executing a 
program, a card array that is associated with the pro- 
gram is initialized in step 502. In one embodiment, a 

30 card array, which is associated with a car, includes card 
marks, or references to card marks, associated with ob- 
jects used by a program, as mentioned above with re- 
spect to Figure 4b. As such, a card array is generally 
used to track objects used in the program. After the card 

35 array is initialized, the program is executed in step 503 
until it is desired either to allocate an object or to store 
a pointer for an object. Allocating an object generally 
involves assigning memory to an object, whereas stor- 
ing a pointer for an object involves storing a pointer to 

40 another object within a first object. 

[0059] During execution, there will periodically be in- 
structions to store a pointer. When a pointer is to be 
stored, as represented by step 504, in step 51 2, an entry 
in the card array which corresponds to the object whose 

45 pointer is to be stored is identified. Once the card array 
entry is identified, the card array entry is marked as dirty 
in step514. Marking the card array entry, i.e., card mark, 
as dirty involves setting the dirty flag of the entry, i.e., 
lowest bit 468 of entry 452a as was described above 

50 with respect to Figure 4b. After the card mark is marked 
as dirty, the pointer is stored in step 516 using any suit- 
able method. Once the pointer is written, process flow 
returns to step 503 where the program continues to ex- 
ecute. When the program terminates, any re-execution 

55 of the program will begin again at step 502 where an 
array of card marks is initialized. 
[0060] Execution also generally provides instructions 
to allocate an object. In one embodiment, returning to 
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step 504, when an object is to be allocated, a determi- 
nation is made in step 506 as to whether enough new 
generation memory is in existence for the object to be 
allocated. If it is determined in step 506 that there is 
enough new generation memory for use in allocating an 
object, then an object is allocated in step 508, and proc- 
ess flow returns to step 503 where a determination is 
made regarding whether there is a pointer to be stored. 
[0061] If the determination in step 506 is that there is 
insufficient new generation memory for an object to be 
allocated, then process flow proceeds to step 51 0 where 
garbage collection is performed. During garbage collec- 
tion, new generation memory, and possibly old genera- 
tion memory, may be cleaned to release sections of new 
generation memory such that an object may be allocat- 
ed. Although it should be appreciated that any suitable 
garbage collection method may be used, one particular- 
ly suitable garbage collection method will be described 
below with respect to Figure 6. After garbage collection 
is performed in step 510, process flow returns to step 
506 where a determination is made regarding whether 
garbage collection has provided enough new genera- 
tion memory for an object, i.e., the object whose alloca- 
tion was deemed necessary in step 503, to be allocated. 
[0062] With reference to Figure 6, the steps associat- 
ed with performing garbage collection will be described 
in accordance with an embodiment of the present inven- 
tion. That is, step 510 of Figure 5 will be described. Gar- 
bage collection may be performed in both new genera- 
tion memory and old generation memory to "free up" 
enough memory space to enable an object to be allo- 
cated. If the system on which garbage collection is to be 
performed is a multi-threaded system, then the threads 
are synchronized in step 602 using any suitable method. 
Once any threads which require synchronization are 
synchronized, garbage collection is performed within 
the new generation memory in step 604. The steps as- 
sociated with one method of performing such a new gen- 
eration garbage collection will be described below with 
reference to Figure 7a. 

[0063] After the new generation garbage collection is 
performed in step 604, process flow proceeds to step 
606 where a determination is made regarding whether 
it is necessary to perform garbage collection for old gen- 
eration memory. In the described embodiment, old gen- 
eration garbage collection is performed periodically. 
That is, after predetermined amounts of time have 
elapsed, old generation garbage collection is per- 
formed. In other embodiments, however, different or ad- 
ditional criteria may be used in the determination of 
whether old generation garbage collection is needed. 
[0064] If it is determined that old generation garbage 
collection is needed, then old generation garbage col- 
lection using a card marking scheme is performed in 
step 608. Although methods associated with garbage 
collection performed on old generation memory using a 
card marking scheme may be widely varied, one suita- 
ble old generation garbage collection method will be de- 



scribed below with respect to Figures 8a and 8b. 
[0065] Once old generation garbage collection is 
completed in step 608, the overall process of performing 
garbage collection to enable an object to be allocated is 

s completed. Therefore, process flow proceeds to step 
506 of Figure 5, which is the determination of whether 
enough new generation memory is available for an ob- 
ject to be allocated. Similarly, if the determination in step 
606 is that no old generation garbage collection is need- 

10 ed, process flow also proceeds to step 506 of Figure 5. 
[0066] Figure 7a is a process flow diagram which il- 
lustrates the steps associated with a new generation 
garbage collection, Lb., step 604 of Figure 6, in accord- 
ance with an embodiment of the present invention. In 

15 step 701, fixed roots are followed. As previously men- 
tioned, fixed roots are roots, e.g., live objects on a stack, 
which directly point into the new generation memory or 
the old generation memory which is being cleaned 
through garbage collection. Following fixed roots typi- 

20 cally entails transitively following references of the 
roots. The actual steps associated with following roots, 
fixed or otherwise, will be described below with respect 
to Figures 7b-7e. 

[0067] After the fixed roots are followed, the card ar- 

25 ray is scanned in step 702 to locate the next entry in the 
card array with either or both a dirty flag or a new gen- 
eration flag that is set. As previously described, in one 
embodiment, " setting" a bit refers to assigning a value 
of 0 0" the bit, whereas "clearing" a bit refers to assigning 

30 a value of "1" the bit. In step 703, a determination is 
made regarding whether an entry, or a card mark, with 
either or both a new generation flag or a dirty flag that 
is set has been found. If such an entry has been found, 
then process flow proceeds to step 704 where it is de- 

35 termined whether the entry is dirty 

[0068] If the determination in step 704 is that the entry 
is dirty, then the card associated with the entry is marked 
as clean in step 707. It should be appreciated that mark- 
ing a card as clean implies marking the card mark as- 

40 sociated with the card as clean. After the card is marked 
as clean in step 707, process flow proceeds to step 708 
where all objects in the card are scanned to locate roots 
which are then followed. As previously mentioned, the 
steps associated with following the roots will be dis- 

45 cussed with reference to Figures 7b-7e below. Once the 
roots are followed, process flow returns to step 702 
where the card array is scanned to locate the next entry, 
i.e., card mark, with either or both a dirty flag or a new 
generation flag that is set. 

so [0069] If the determination in step 704 is that the entry 
is not dirty, then the entry has a new generation flag that 
is set. In other words, the entry includes an inter-gener- 
ational pointer. If the entry is not dirty, process flow 
moves from step 704 to step 706 where a determination 

55 js made regarding whether the root array associated 
with the entry has overflowed. An overflowed root array 
is a root array which does not have include enough 
space to accept the insertion of an additional root. If it 
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is determined that the root array associated with the en- 
try is overflowed, then process flow moves to step 707 
where the card associated with the entry is marked as 
clean. 

[0070] From step 71 4, process flow moves to step 71 8 s 
in which the block associated with the entry is scanned, 
and the roots associated with the block are followed. 
Then, process flow returns to step 702, which is the step 
of scanning the card array to look for the next entry in 
the card array with the lowest bit set to zero. 
[0071] When a suitable entry, that is, an entry with the 
lowest bit set to zero, is not found in step 703, then the 
roots within the new generation memory are followed 
until ail copied objects have been scanned in step 710. 
Once all copied objects have been scanned, the new 
generation garbage collection process is completed. 
[0072] In general, garbage collection involves follow- 
ing roots, as previously mentioned. Referring next to 
Figure 7b, the steps associated with following a single 
root will be described in accordance with an embodi- 
ment of the present invention. The process begins with 
a determination in step 720 of whether the root points 
into a memory area in which garbage collection is oc- 
curring. If it is determined that the root does not point 
into an area that is being garbage collected, then the 
process of following the root is completed. On the other 
hand, if the determination in step 720 is that the root 
does indeed point into an area in which garbage collec- 
tion is occurring, then, in step 721, a determination is 
made as to whether the header field of the card mark 
holds a forwarding pointer. That is, a determination is 
made regarding whethera new memory location is iden- 
tified by a forwarding pointer associated with the card 
mark. 

[0073] If the determination is that the header field 
does hold a forwarding pointer, then process flow 
moves from step 721 to step 722 where the root is up- 
dated to the new location identified by the forwarding 
counter. After the root is updated, the card mark is up- 
dated accordingly in step 728. The steps associated 
with updating a card mark will be described below with 
reference to Figure 7c. Once the card mark is updated, 
then the process of following a root is completed. 
[0074] Returning to step 721, if it is determined that 
the header field does not hold a forwarding pointer, then 
the object identified by the root is copied to a new loca- 
tion, and a forwarding pointer is inserted in the header 
of the object in step 724. The forwarding pointer identi- 
fies the new location of the object. When the forwarding 
pointer has been inserted in the header, the root is up- 
dated to the new location in step 726. Then, in step 728, 
the associated card marking is updated, and the proc- 
ess of following a root is completed. 
[0075] With respect to Figures 7c-7e, the steps asso- 
ciated with updating a card mark, i.e. t step 728 of Figure 
7b, will be described in accordance with an embodiment 
of the present invention. In step 740, a determination is 
made as to whether the pointer points from the old gen- 



eration to the new generation. If the pointer does point 
from the old generation to the new generation, then in 
step 746, it is determined whether the new generation 
flag is set to indicate that there is a pointer from the old 
generation to the new generation. 
[0076] In step 752, a determination is made regarding 
whether the root array has overflowed when it is deter- 
mined in step 746 that the new generation flag is set. If 
the root array is overflowed, then the process of updat- 
ing a card mark is completed. If, however, the root array 
is not overflowed, then a determination is made in step 
754 as to whether the root array is full. If it is determined 
that the root array is not full, process flow proceeds to 
step 750 in which the root, i.e., the root that is being 
followed, is inserted into the root array, and the process 
of updating a card mark is completed. If the root array 
is determined to be full in step 754, then process flow 
moves to step 755 where the card mark is set to indicate 
that there is an overflow of the root array. After the card 
mark is set, the card mark update process is completed. 
[0077] Returning to step 746 and the determination of 
whether the new generation flag is set, when it is deter- 
mined that the new generation pointer is not set, then in 
step 747, the new generation pointer is set to indicate 
that the pointer points from the old generation to the new 
generation. A root array is allocated and the card mark 
is set to point to the allocated root array in step 748. 
From step 748, process flow proceeds to step 749 which 
is the determination of whether the allocation of the root 
array was successful. If the allocation of the root array 
was successful, then the followed root is inserted in the 
root array in step 750. On the other hand, if the allocation 
of the root array was not successful, then process flow 
proceeds to step 755 where the card mark is set to in- 
dicate that the root array is overflowed. In one embodi- 
ment, setting the card markto indicate that the root array 
is overflowed involves setting the pointer, /.a, the 27-bit 
pointer, in the card mark to null. 
[0078] If the determination in step 740 was that the 
pointer does not point from the old generation to the new 
generation, then process flow proceeds to step 742 
which is the determination of whether there is a pointer 
which points to a lower train in the old generation. If it is 
determined that the pointer points to a lower train in the 
old generation, then a determination is made in step 760 
as to whether the new generation flag is set to indicate 
that there is a pointer from the old generation to the new 
generation. If the indication is that the new generation 
flag is set, then process flow proceeds to step 775, 
which is the determination of whether the lower train flag 
is set. In the described embodiment, the lower train flag 
is the third lowest bit in the card mark, and indicates 
whether the pointer points into a lower train, as de- 
scribed above. If the determination is that the lower train 
flag is set, the process of updating the card mark is com- 
pleted. Alternatively, if the determination is that the lower 
train flag is not set, then the lower train flag is set in step 
776. Once the lower train overflow flag is set, then the 
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card mark update process is completed. 
[0079] If it is determined in step 760 that the new gen- 
eration flag is not set, then process flow moves to step 

766 where it is determined whether the lower train flag 

is set. If the determination in step 766 is that the lower s 
train flag is not set, then the lower train flag is set in step 

767 to indicate the existence of a pointer to a lower train. 
Once the lower train flag is set, a root array is allocated 
and the card mark is set to point to the allocated root 
array in step 768. A determination is then made in step 
769 regarding whether the allocation of the new root ar- 
ray was successful. If the allocation was successful, 
then in step 770, the followed root is inserted in the root 
array, in the event that the root is not already present in 
the root array. Then, the process of updating the card 
mark is completed. On the other hand, if the allocation 
of a new root array in step 769 was not successful, then 
process flow moves from step 769 to step 762 where 
the card mark is set to indicate a root array overflow. 
After the card mark is set to indicate a root array over- 
flow, the process of updating the card mark is complet- 
ed. 

[0080] Returning to step 766, if the determination is 
that the lower train flag is set to indicate that there is a 
pointer to a lower train, then a determination is made in 
step 772 regarding whether the corresponding root ar- 
ray is overflowed. If the root array is overflowed, then 
the card mark is set to indicate a root array overflow in 
step 762. Alternatively, if the root array is determined 
not to be overflowed in step 772, then the followed root 
is inserted in the root array in step 770, if the root is not 
already present in the root array. 
[0081] Referring back to step 742, which is the step 
of determining if a pointer points to a lower train in the 
old generation, if it is determined that a pointer does not 
point to a lower train in the old generation, then in step 
744, a determination is made as to whether a pointer 
points to a lower car in the same train. If a pointer does 
not point to a lower car in the same train, then the card 
mark update process is completed. If, however, the de- 
termination is that a pointer does point to a lower car in 
the same train, then process flow proceeds to step 780, 
which is the determination of whether the new genera- 
tion flag is set to indicate that there is a pointer to a new 
generation. 

[0082] If the indication in step 780 is that the new gen- 
eration flag is set, then a determination is made in step 
782 as to whether the same train flag is set. That is, a 
determination is made regarding whether there is a 
pointer into a lower car of the same train. If the same 
train flag is set, then the process of updating a card mark 
is completed. Alternatively, if the same train flag is not 
set, then the same train flag is set in step 783. Once the 
same train flag is set, then the process of updating a 
card mark is completed. 

[0083] When it is determined in step 780 that the new 
generation flag is not set, then process flow proceeds 
to step 786 where a determination is made regarding 



whether the lower train flag of the card mark is set to 
indicate that there is a pointer to a lower train. If the lower 
train flag is set, then process flow proceeds to step 782 
where a determination is made regarding whether the 
same train flag is set. 

[0084] If the bwer train flag is not set, or indicates that 
pointers to a lower train are not in existence, then proc- 
ess flow moves from step 786 to step 788 where a de- 
termination is made regarding whether the same train 
flag of the card mark is set. Step 788, in other words, is 
the determination of whether the card mark indicates 
that there is a pointer to a lower card of the same train. 
If it is determined that the same train flag is set, then in 
step 790, it is determined whether a root array associ- 
ated with the card mark is overflowed. If the root array 
is overflowed, then the card mark is set to indicate that 
the root array is overflowed in step 793. Alternatively, if 
it is determined that the root array is not overflowed, 
then, in step 792, the root is inserted in the root array in 
the event that the root is not already present in the root 
array. After the root is inserted in the block array, if nec- 
essary, the process of updating a card mark is complet- 
ed. 

[0085] Returning to step 788, if it is determined that 
the same train flag is not set, then a root array is allo- 
cated in step 794. Further, the card mark is set to point 
to the allocated root array. In step 796, it is determined 
whether the allocation of the root array was successful. 
If the allocation of the root array was not successful, then 
the card mark is set to indicate a root array overflow in 
step 782. On the other hand, if the allocation of the root 
array was successful, then process flow proceeds to 
step 792 where the root is inserted into the root array, if 
the root is not already present in the root array. 
[0086] Figures 8a and 8b are process flow diagrams 
which illustrate the steps associated with performing 
garbage collection in old generation memory, i.e., step 
608 of Figure 6, in accordance with an embodiment of 
the present invention. In step 802, fixed roots or, in this 
embodiment, roots which directly point into old genera- 
tion memory, are followed. The steps associated with 
following the fixed roots, according to an embodiment 
of the present invention, were described above with re- 
spect to Figures 7b-7e. 

[0087] Roots from the new generation are followed in 
step 804. That is, the associations of roots which point 
from the new generation to the old generation are fol- 
lowed. Process flow moves from step 804 to step 806 
in which the card array, or the array of card marks, is 
scanned in order to locate the next entry which has a 
lower train flag that is set. In step 808, it is determined 
whether such an entry, i.e., an entry which has a lower 
train flag that is set, has been found. If it is determined 
that such an entry has been found, then a determination 
is made in step 81 2 regarding whether the entry that was 
found has either, or both, a new generation flag that is 
set or a root array which is overflowed. If either, or both, 
the new generation flag is set or a root array is over- 
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flowed, then in step 814,, all the objects in the card are 
scanned for roots, and the roots are followed. Again, the 
steps associated with following a root were previously 
discussed with respect to Figures 7b-7e. After the roots 
are followed, process flow returns to step 806 where the 
card array is scanned to locate the next entry which has 
a lower train flag that is set. 

[0088] If it is determined in step 812 that the entry, /. 
ft, card mark, that was found in step 808 does not have 
a new generation flag that is set or a root array that is 
overflowed, then process flow moves to step 81 6 where 
the root associated with the entry is scanned, and the 
roots associated with the root array are followed. After 
the roots are followed, the card array is scanned in step 
806 for the next entry which has a lower train flag that 
is set. 

[0089] Returning to step 808, if scanning the card ar- 
ray looking for an entry which has a lower train flag that 
is set results in no entry being found, then in step 820, 
the roots are followed within the old generation until ail 
copied objects have been scanned. In one embodiment, 
objects in one train which are referenced from other 
trains are copied into those trains. When all copied ob- 
jects have been scanned, a determination is made in 
step 830 regarding whether a root which points into the 
lowest train was encountered during the scanning proc- 
ess. If the determination is that a root into the lowest 
train was not encountered, then the entire lowest train 
is released in step 840. In other words, old generation 
memory held by the lowest train is freed. The entire low- 
est train may be freed due to the fact that if no pointers 
into the lowest train exist, the lowest train contains only 
garbage. It should be appreciated that cyclic structures 
which reference each other and are located in different 
cars of the same train may be collected when the entire 
lowest train is freed. Once the entire lowest train is freed, 
the steps associated with an old generation garbage col- 
lection are completed. 

[0090] If it is determined in step 830 that a root into 
the lowest train was encountered, then in step 832, the 
card array is scanned to look for the next entry, i.e., card 
mark, which has a same train flag that is set. In step 834, 
a determination is made regarding whether an entry with 
a same train flag that is set has been found. If the de- 
termination is that an entry with a same train flag that is 
set has not been found, then the roots are followed with- 
in the old generation until all copied objects have been 
scanned in step 836. Scanning all copied objects in- 
volves, in one embodiment, a transitive search for point- 
ers.. Once all copied objects have been scanned, the 
lowest car in the lowest train is released in step 837, and 
an old generation garbage collection process is com- 
pleted. 

[0091] Returning to step 834, if the determination is 
that an entry, or card mark, with a same train flag that is 
set has been found, then process flow proceeds to step 
838 where a determination is made regarding whether 
the entry has a new generation flag that is set, a lower 



train flag that is set, or a root array that is overflowed. If 
the entry has any of or all of a new generation flag that 
is set, then in step 850, all objects in the card are 
scanned for roots, which are followed. Once the roots 
are followed, process flow returns to step 832 where the 
card array is once again scanned to look for the next 
entry which has a same train flag that is set. 
[0092] If the determination in step 838 is that the entry 
found in step 834 does not include a new generation flag 
that is set, a lower train flag that is set, or a root array 
that is overflowed, then the root array associated with 
the entry is scanned in step 856, and the roots in the 
root array are followed. After the roots are followed, 
process flow returns to step 832 where the card array is 
scanned to look for the next entry which has a same 
train flag that is set. 

[0093] It should be appreciated that a computer pro- 
gram which uses inter-generational garbage collection 
in accordance with the present invention may be imple- 
mented on a variety of different computer systems. Fig- 
ure 9 illustrates a typical, general purpose computer 
system suitable for implementing the present invention. 
The computer system 930 includes any number of proc- 
essors 932 (also referred to as central processing units, 
or CPUs) that are coupled to memory devices including 
primary storage devices 934 (typically a read only mem- 
ory, or ROM) and primary storage devices 936 (typically 
a random access memory, or RAM). As is well known in 
the art, ROM acts to transfer data and instructions uni- 
directionally to the CPU 932, while RAM is used typically 
to transfer data and instructions in a bi-directional man- 
ner. Both primary storage devices 934, 936 may include 
any suitable computer-readable media. A secondary 
storage medium 938, which is typically a mass memory 
device, is also coupled bi-directionally to CPU 932 and 
provides additional data storage capacity. The mass 
memory device 938 is a computer-readable medium 
that may be used to store programs including computer 
code, data and the like and is typically a storage medium 
such as a hard disk or a tape that are generally slower 
than primary storage devices 934, 936. Mass memory 
storage device 938 may take the form of a magnetic or 
paper tape reader or some other well-known device. It 
will be appreciated that the information retained within 
45 the mass memory device 938, may, in appropriate cas- 
es, be incorporated in standard fashion as part of RAM 
936 as virtual memory. A specific primary storage device 
934 such as a CD-ROM may also pass data uni-direc- 
tionally to the CPU. 
so [0094] CPU 932 is also coupled to one or more input/ 
output devices 940 that may include; but are not limited 
to, devices such as video monitors, track balls, mice, 
keyboards, microphones, touch-sensitive displays, 
transducer card readers, magnetic or paper tape read- 
55 ers, tablets, styluses, voice or handwriting recognizers, 
or other well-known input devices such as, of course, 
other computers. Finally, CPU 932 optionally may be 
coupled to a computer or telecommunications network, 
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e.g., an Internet network or an intranet network, using a 
network connection as shown generally at 912. With 
such a network connection, it is contemplated that the 
CPU 932 might receive information from the network, or 
might output information to the network in the course of 
performing the above-described method steps. Such in- 
formation, which is often represented as a sequence of 
instructions to be executed using CPU 932, may be re- 
ceived from and outputted to the network in the form of 
a computer data signal embodied in a carrier wave. The 
above-described devices and materials will be familiar 
to those of skill in the computer hardware and software 
arts. 

[0095] Although only a few embodiments of the 
present invention have been described, it should be un- 
derstood that the present invention may be embodied 
in many other specific forms without departing from the 
spirit or scope of the invention. By way of example, steps 
involved with new generation garbage collection and the 
old generation garbage collection may be reordered. 
Steps may also be removed or added without departing 
from the spirit or the scope of the present invention. 
[0096] While generational garbage collection has 
been described as being performed in a new generation 
and an old generation of memory, generational garbage 
collection may be performed over many generations of 
memory. That is, generational garbage collection meth- 
ods of the present invention may be performed on mem- 
ory that is divided into multiple generations, e.g., a new 
generation, an "intermediate generation," and an old 
generation, which are segregated by the age of objects 
within each generation. It should be appreciated that for 
embodiments in which there are multiple generations, 
an inter-generational pointer may generally point be- 
tween any two generations. 

[0097] The card mark has been described as being a 
32-bit word which includes a 27-bit pointer, a reserved 
bit, a same train flag, a lower train flag, a new generation 
flag, and a dirty flag. However, it should be appreciated 
that the card mark may be varied without departing from 
the spirit of the scope of the present invention. For ex- 
ample, the card mark may include fewer than 32 bits or 
more than 32 bits, depending at least in part upon the 
particular requirements of a given system. Alternatively, 
the bits within a card mark may also be widely varied. 
By way of example, in one embodiment, the 32-bits with- 
in a card mark may include a 26-bit pointer and two n 
status indicator" bits, or tag bits. The status indicator bits 
may be arranged such that different combinations of val- 
ues for the status indicator bits indicate whether a card 
mark is dirty, clean, includes a new generation pointer, 
or does not include a new generation pointer. The card 
mark may also include a lower train flag which indicates 
whether there are any pointers to a lower train, a same 
train flag which indicates whether there are any pointers 
within a given train to a lower car in that train, a lower 
train overflow flag, and a same train overflow flag. 
[0098] Further, although the lowest bits within a card 



mark are described as being flags which are used to in- 
dicate, for example, whether the card mark is dirty, as 
described above, it should be appreciated that the flags 
within a card mark may be located in any suitable posi- 

5 tion within the card mark. The bits which represent flags 
may be the highest bits within a card mark. Alternatively, 
the bits may be interspersed throughout a card mark. 
[0099] Although the size of a car in old generation 
memory has been described as being fixed, it should be 

10 appreciated that, in one embodiment, the size of a car 
may be dynamically allocated. That is, the size of a car 
may be determined based upon the particular require- 
ments of objects which are to be placed within the car. 
By way of example, the size of a car may be allocated 

15 during the course of garbage collection process to min- 
imize the number of pointers which originate with ob- 
jects within the car without departing from the spirit or 
the scope of the present invention. 
[0100] It should be appreciated that conventional 

20 methods for garbage collection may occasionally be im- 
plemented within old generation memory. By way of ex- 
ample, in some cases, it may be possible for old gener- 
ation memory to become full. When old generation 
memory is full, performing old generation garbage col- 

25 lection on a car may not free up a sufficient amount of 
memory for immediate use. As such, a conventional gar- 
bage collection process, such as a mark sweep collec- 
tion process, may be implemented to free as much old 
generation memory as possible in the event that the old 

30 generation memory is full without departing from the 
spirit or the scope of the present invention. Therefore, 
the present examples are tobe considered as illustrative 
and not restrictive, and the invention is not to be limited 
to the details given herein, but may be modified within 

35 the scope of the appended claims along with their full 
scope of equivalents. 

Claims 

40 

1. A computer-implemented method for dynamically 
managing memory associated with a computer sys- 
tem, the memory including a first memory section 
and a second memory section that is divided into a 
45 plurality of blocks, the blocks in the second memory 
section each having an associated marker, the 
method comprising: 

performing a first garbage collection on the first 
50 memory section; 

performing a second garbage collection on a 
selected one of the blocks in the second mem- 
ory section; 

performing a third garbage collection on the se- 
55 lected block in the second memory section, 

wherein the third garbage collection includes 
determining whether the selected block in- 
cludes a first object which references a second 
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object which is not included in the selected 
block based at least in part on a status indicated 
by the marker associated with the selected 
block, wherein the status includes an indication 
of whether the reference to the second object 5 
was stored after the second garbage collection 
was performed; and 

when the reference to the second object was 
stored after the second garbage collection was 
performed, creating a new root array using the io 
selected marker. 

A computer-implemented method as recited in 
claim 1 wherein when it is determined that the first 
object does not reference a second object which is *5 
not included in the selected block, the method fur- 
ther includes releasing the selected block. 

A computer-implemented method as recited in any 
one of the preceding claims wherein when it is de- 20 
termined that the selected block includes a first ob- 
ject which references a second object, the step of 
performing the third garbage collection further in- 
cludes: 

25 

determining whether the second object is in the 
first memory section using the selected block 
marker; and 

when it is determined that the second object is 
in the first memory section, a root array asso- 30 
ciated with the selected block marker is updat- 
ed to insure that the root array associated with 
the selected block marker includes a pointer to 
the second object. 

35 

A computer-implemented method as recited in one 
of claims 1 and 2 wherein when it is determined that 
the selected block includes a first object which ref- 
erences a second object, the step of performing the 
third garbage collection further includes: *o 

determining whether the second object is in the 
second memory section using the selected 
block marker; and 

when it is determined that the second object is 45 
in the second memory section, a root array as- 
sociated with the selected block marker is 
scanned to identify references to other objects. 

A computer-implemented method as recited in so 
claim 4 further including following the references to 
other objects. 

A computer-implemented method as recited in one 
of claims 1 and 2 wherein the plurality of blocks are 55 
arranged as a plurality of trains, the selected block 
being included in a first one of the plurality of trains, 
the step of performing the third garbage collection 



further including: 

determining whether the second object is in a 
second one of the plurality of trains based at 
least in part on the status indicated by the mark- 
er associated with the block. 

7. A computer-implemented method as recited in 
claim 6 wherein when it is determined that the sec- 
ond object is not in a second one of the plurality of 
trains, the method further includes releasing the 
second train. 

8. A computer-implemented method as recited in one 
of claims 1 and 2 wherein the plurality of blocks are 
arranged as a plurality of cars, the plurality of cars 
further being arranged as a plurality of trains, the 
selected block being included in a first one of the 
plurality of cars that forms a selected one of the plu- 
rality of trains, the step of performing the third gar- 
bage collection further including: 

determining whether the second object is in a 
second one of the plurality of cars that forms 
the selected train based at least in part on the 
status indicated by the marker associated with 
the block. 

9. A computer-implemented method as recited in 
claim 8 wherein when it is determined that the sec- 
ond object is not in the second car of the selected 
train, the method further includes releasing the sec- 
ond car. 

10. A computer-implemented method for dynamically 
managing memory associated with a computer sys- 
tem, the memory being divided into a plurality of 
blocks, the blocks each having an associated mark- 
er, the method comprising: 

performing a first garbage collection on a se- 
lected one of the blocks; 
performing a second garbage collection on the 
selected block, wherein the second garbage 
collection includes determining whether the se- 
lected block includes a first object which refer- 
ences a second object which is not included in 
the selected block based at least in part on a 
status indicated by the marker associated with 
the selected block, the status indicated by the 
marker including an indication of whether the 
reference to the second object was stored after 
the first garbage collection was performed; and 
when the reference to the second object was 
stored after the first garbage collection was per- 
formed, creating a new root array using the se- 
lected block. 
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11. A computer-implemented method as recited in 
claim 1 0 wherein when it is determined that the first 
object does not reference a second object which is 
not included in the selected block, the method fur- 
ther includes releasing the selected block. 

12. A computer-implemented method as recited in one 
of claims 10 and 11 wherein the plurality of blocks 
are arranged as a plurality of trains, the selected 
block being included in a first one of the plurality of 
trains, the step of performing the garbage collection 
further including: 

determining whether the second object is in a 
second one of the plurality of trains based at 
least in part on the status indicated by the mark- 
er associated with the block; and 
when it is determined that the second object is 
not in a second one of the plurality of trains, the 
method further includes releasing the second 
train. 

13. A computer-implemented method as recited in 
claim 10 further including an additional memory 
section, wherein when it is determined that the sec- 
ond object is not included in the selected block, the 
step of performing the garbage collection on the se- 
lected block further includes determining whether 
the second object is included in the additional mem- 
ory section based at least in part on the status indi- 
cated by the marker associated with the selected 
block. 

14. A computer-implemented method for allocating a 
selected object in computer memory, the computer 
memory including a first section, a second section, 
and an array of words associated with elements in 
the second section, the words being arranged to in- 
dicate whether the contents of their associated el- 
ements reference objects in the first section, the 
method comprising: 

determining whether the first section is suitable 
for the selected object to be allocated; 
allocating the selected object when it is deter- 
mined that the first section is suitable for the 
object to be allocated; and 
performing a garbage collection in the first sec- 
tion when it is determined that the first section 
is not suitable for the selected object to be al- 
located, wherein performing the garbage col- 
lection includes scanning the array of words to 
locate selected words that indicate that their as- 
sociated elements in the second section refer- 
ence particular objects in the first section, and 
wherein the particular objects in the first section 
are retained during the garbage collection. 



15. A computer-implemented method as recited in 
claim 14 wherein when the selected markers that 
indicate that their associated elements in the sec- 
ond section reference the particular objects are lo- 
5 cated, performing the garbage collection in the first 
section further includes: 

following associations of roots within the asso- 
ciated elements in the second section, wherein 
10 following the associations of the roots includes 

updating the roots to new locations within the 
computer memory and updating the selected 
words. 

is 16. A computer-implemented method as recited in 
claim 15 wherein updating the selected words in- 
cludes: 

determining when a selected one of the roots 
20 js in the second section and references a se- 

lected one of the particular objects is in the first 
section; and 

when it is determined that the selected root is 
in the second section and references the se- 
25 lected particular object in the first section, up- 

dating the selected words to indicate that the 
selected root is in the second section and the 
selected particular object is in the first section. 

30 17. A computer-implemented method as recited in 
claim 14 further including: 

performing a garbage collection in the second 
section, wherein performing the garbage col- 

35 lection includes following associations of roots 

associated with selected ones of the elements, 
the roots being associated with the new gener- 
ation, whereby following the associations of the 
roots involves updating some of the words in 

40 the array of words. 

18. A marker for use in a computer system including a 
first memory section and a second memory section 
that is arranged as a plurality of elements, the mark- 

45 er being associated with a first element selected 
from the plurality of elements, the marker compris- 
ing: 

a first indicator arranged to identify whether the 
so first selected element references an object con- 

tained within the first memory section. 

19. A marker for use in a computer system as recited 
in claim 18 further including a reference to the ob- 

55 ject, the reference to the object being a pointer to 
an array which contains an address for the object. 

20. A computer system comprising: 
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memory including a first memory section and a 
second memory section that is segmented into 
a plurality of blocks; 

an array of markers, each marker correspond- 
ing to an associated block in the second mem- 
ory section, the markers being configured to in- 
dicate when their associated blocks reference 
objects outside of their associated block; 
a set of root arrays, the root arrays being ar- 
ranged to hold addresses of the objects, where- 
in selected markers from the array of markers 
are associated with the set of root arrays; 
a first garbage collector for reclaiming space 
within the first memory section; and 
a second garbage collector for reclaiming 
space within the second memory section based 
at least in part upon the status of the markers 
in the array of markers. 

21. A computer system as recited in claim 20 wherein 
a first marker selected from the array of markers in- 
cludes a section indicator that identifies when the 
associated block of the first marker references a 
first object in the first memory section. 

22. A computer system as recited in one of claims 20 
and 21 wherein the plurality of blocks is arranged 
as a plurality of cars, the plurality of cars further be- 
ing arranged as a plurality of trains. 

23. A computer system comprising: 
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ond garbage collection includes determining 
whether a block selected from the plurality of 
blocks includes a first object which references 
a second object which is not included in the se- 
lected block based at least in part on a status 
indicated by the marker associated with the se- 
lected block; and 

a computer readable medium that stores the 
computer codes. 

25. A computer program product for causing a proces- 
sor of a computer system to dynamically manage 
memory associated with the computer system, the 
computer program product comprising: 

computer code that performs a first garbage 
collection in a first memory section of the com- 
puter; 

computer code that performs a second garbage 
collection on a second memory section of the 
computer, the second memory section being dk 
vided into a plurality of blocks, wherein the sec- 
ond garbage collection includes determining 
whether a block selected from the plurality of 
blocks includes a first object which references 
a second objecf which is not included in the se- 
lected block based at least in part on a status 
indicated by the marker associated with the se- 
lected block; and 

a computer data signal embodied in a carrier 
wave that represents the computer codes. 



memory that is segmented into a plurality of 
blocks; 

an array of markers, each marker correspond- 35 
ing to an associated block in the memory, the 
markers being configured to indicate when their 
associated blocks reference objects outside of 
their associated block; 

a set of root arrays, the root arrays being ar- *o 
ranged to hold addresses of the objects, where- 
in selected markers from the array of markers 
are associated with the set of root arrays; and 
a garbage collector for reclaiming space within 
the memory based at least in part upon the sta- ^ 
tus of the markers in the array of markers. 



24. A computer program product for dynamically man- 
aging memory associated with a computer system, 
the computer program product comprising: 50 

computer code that performs a first garbage 
collection in a first memory section of the com- 
puter; 

computer code that performs a second garbage 55 
collection on a second, memory section of the 
computer, the second memory section being di- 
vided into a plurality of blocks, wherein the sec- 



Patant nrovirlpr! hv Snnhnip Minn PI I P. - httn /Awww simhniR mm 



EP 0 940 755 A1 




* 



figure 1 



Patent nroviHpH hv Si inhn ip Minn PMC - httrv//www si inhn ip mm 



EP 0 940 755 A1 




Patent nrnvirifirt hv SunhniA Minn PI I C. - httrW/www siinhnifl cnm 



EP 0940 755 A1 




Patnnt nrnvirifiri hv Runhnin Minn PI I C . httn7/www sunhn 



EP 0 940 755 A1 




Patent nrnvirteH h v Si in hn if Minn PI I C. - hrtn-//www si inhn in nnm 



EP 0 940 755 A1 




Patpnt nmvirlerl hu Simhme Minn PI I C. - httn7A«ww 



EP 0 940 755 A1 




EXECUTE PROGRAM 
UNTIL OBJECT 
ALLOCATION IS 
NECESSARY OR 
POINTER IS STORED 



502 



■503 



508 



ALLOCATE OBJECT 




N 



PERFORM GARBAGE 
COLLECTION 



512 



DETERMINE CARD 
ARRAY ENTRY 
CORRESPONDING TO 
OBJECT WHOSE 
POINTER IS TO BE 
STORED 



I 



514 



MARK CARD ARRAY 
ENTRY AS DIRTY 



516 



STORE POINTER 



•510 



Patent nmvidftH hv SunhniA Minn PI I P. - httn-//www snnhnift nnm 



EP 0 940 755 A1 



510 



SYNCHRONIZE THREADS IF 
SYSTEM ISA 

MULTI-THREADED SYSTEM 



602 



PERFORM NEW 
GENERATION GARBAGE 
COLLECTION 



604 



■606 



IS OLD 
GENERATION 
GARBAGE 
COLLECTION 
NEEDED? 




PERFORM OLD 
GENERATION GARBAGE 
COLLECTION 



■608 



figure 6 



Patent nrnvirtftd hv SitnhniA Minn PI I C. - httn//www sunhnin mm 



EP 0 940 755 A1 



604 



FOLLOW FIXED ROOTS 



SCAN CARD ARRAY 
LOOKING FOR NEXT 
ENTRY WITH DIRTY OR 
NEW GENERATION FLAG 
SET 



701 



702 



Jyjure 7a 



FOLLOW ROOTS WITHIN 
NEW GENERATION UNTIL 
ALL COPIED OBJECTS 
HAVE BEEN SCANNED 




710 



MARK CARD AS CLEAN 



SCAN ALL OBJECTS IN 
CARD FOR ROOTS AND 
FOLLOW ROOTS 



CLEAR NEW GENERATION 
FLAG 



^716 



^718 



SCAN ROOT ARRAY 
ASSOCIATED WITH ENTRY 
AND FOLLOW ROOTS 



Patent nrnvirtpH hv SunhniP Minn PI I C. - httrv//www sunhniA mm 



EP 0 940 755 A1 



BEGIN 
[FOLLOWING] 
A ROOT 



720 



DOES ROOT 
POINT INTO AREA 
BEING GARBAGE 
.COLLECTED? 



N 




END 



721 



DOES HEADERS 
FIELD HOLD 
FORWARDING 
^POINTER? 



COPY OBJECT TO NEW 
LOCATION AND INSERT 
FORWARDING POINTER 
IN HEADER 



1 


f 


UPDATE ROOT TO NEW 
LOCATION 






UPDATE CARD MARK 



UPDATE ROOT TO NEW 
LOCATION IDENTIFIED BY 
FORWARDING POINTER 



724 



726 



728 




END 



Jyure 76 



Patent nrnviHprl hv Snnhni* Minn PI I P. - httn7/www RimhniA mm 



EP 0 940 755 A1 




Patent nrnv/irtad hv Snnhnift Minn PI I C. - httrv//www siinhma mm 



EP 0 940 755 A1 




Patent nrnvirtprl hv Sunhnin Minn PI I C. - hftn-//www sunhn in mm 



EP 0 940 755 A1 




Patent nrnvidftd hv Rnnnm* Minn PI I P. - httrv//www siinhmp mm 



EP 0 940 755 A1 




608 



FOLLOW FIXED ROOTS 



FOLLOW ROOTS FROM 
NEW GENERATION 



I 



SCAN CARD ARRAY 
LOOKING FOR NEXT 
ENTRY WHICH HAS 
LOWER TRAIN FLAG 
SET 



802 



804 



806 




816 



SCAN ROOT ARRAY 
ASSOCIATED WITH ENTRY 
AND FOLLOW ROOTS 



CLEAR LOWER TRAIN 
FLAG 



815 



812 



IS NEW 
GENERATION 
FLAG SET OR 
DID ROOT ARRA\ 
)VERFLOW? 



Jigum8a 



814 



SCAN ALL OBJECTS IN 
CARD FOR ROOTS AND 
FOLLOW ROOTS 



Patent nrnvirlfiri hv Snnhni* Minn PI I C. - htfn-//www siinhmn mm 



EP 0 940 755 A1 



5S 
54 




Patpnt nrovidpd hv Sunhnip. Minn 



PI I C. - httrv//www siinhniP. mm 



EP 0 940 755 A1 



930 



\ 



938 



Secondary 
Storage 



940 




I 



r 



932 



PROCESSOR 



I 



£ 



912 



Network 



934 




Tyjure9 



PatAnt nmviHftd hv Snnhnin Minn PI I C. - httn-//www snnhnip nnm 



EP 0 940 755 A1 



J 



European Patent 
Office 



EUROPEAN SEARCH REPORT 



Apptkatlon Number 

EP 99 30 1472 



DOCUMENTS CONSIDERED TO BE RELEVANT 



Categoiy 



Citation ol document with indication, where appropriate. 
ol relevant passages 



Relevant 

to claim 



CLASSIFICATION OF THE 
APPLICATION (tnt.CI.6) 



Y 
A 



HOSKING ET AL: "Remembered sets can also 
play cards" 

POSITION PAPER FOR OOPSLA '93 WORKSHOP ON 
MEMORY MANAGEMENT ANO GARBAGE COLLECTION 
(WASHINGTON, DC, OCTOBER 1993), 
XP002105705 

Available from Internet <URL: 

ftp : //ftp . cs . utexas . edu/pub/garbage/GC93/h 

osk1ng.ps> 9 June 1999 

* the whole document * 



SELIGMAN ET AL: "Incremental Mature 
Garbage Collection Using the Train 
Algorithm" 

PROCEEDINGS OF ECOOP'95, NINTH EUROPEAN 
CONFERENCE ON OBJECT-ORIENTED PROGRAMMING, 
LECTURE NOTES IN COMPUTER SCIENCE, VOL. 
952, PP. 235-252, SPRINGER VERLAG, 1995. 
ISBN 3-540-60160-0. ,26 March 1995, 
XP002105706 

Available from Internet <URL: 

http ://www. dalmi . aau .dk/l beta/Papers/Train 

/train. ps> 9 June 1999 

* page 1 - page 7 * 



HUDSON ET AL: "Incremental Collection of 
Mature Objects" 

INTERNATIONAL WORKSHOP ON MEMORY 

MANAGEMENT, ST. MALO, FRANCE, SEPT. 1992, 

PP. 388-403, XP0O2105707 

Available from Internet <URL: 

ftp : //ftp . cs . umas s . edu/pub/os 1 /paper s/i wmm 

92.ps.Z> 9 June 1999 

* page 6 - page 10 * 



14-18,23 



G06F12/02 



1-13, 
20-22 

24,25 



1-13, 
20-22 

1-25 



-/- 



The present search report has been drawn up for all claims 



TECHNICAL FIELDS 
SEARCHED (lnt.CI.6) 



G06F 



Placa ol search 

THE HAGUE 



Date of completion ol the search 

11 June 1999 



Nielsen, 0 



CATEGORY OF CITED DOCUMENTS 

X : particularly relevant if taken alone 

Y : particularly relevant fl combined with another 

document or the same category 
A : technological background 
O : non- written disclosure 
P : intermediate document 



T : iheory or prineple underlying the Invention 
E : earlier patent document, but published on, or 

after the tHing date 
D : document cited in the application 
L : document cited for other reaaone 



& : member of the same patent famfly, corresponding 
document 



PatP.nt nrnvirlftH hv SnnhniA Minn PI I P. - httn7/www simhntA nnm 



EP 0 940 755 A1 



European Patent 
Office 



EUROPEAN SEARCH REPORT 



Application Number 

EP 99 30 1472 



DOCUMENTS CONSIDERED TO BE RELEVANT 



Category 



Citation of document with indication, where appropriate, 
of relevant passages 



Relevant 
to claim 



CLASSIFICATION OF THE 
APPLICATION (IntCU) 



HOSKING A L ET AL: "A COMPARATIVE 

PERFORMANCE EVALUATION OF WRITE BARRIER 

IMPLEMENTATIONS" 

ACM SIGPLAN NOTICES, 

vol. 27, no. 10, 1 October 1992, pages 

92-109, XP000327291 

* page 95, left-hand column - page 98, 

left-hand column * 



1-25 



TECHNICAL FIELDS 
SEARCHED (lnt.CI.6) 



The present search report has been drawn up tor all claims 



Plac*ol search 

THE HAGUE 



Oat* of eomptttion of tht search 

11 June 1999 



Examiner 

Nielsen, 0 



CATEGORY OF CITED DOCUMENTS 

X : particularly relevant if taken atone 

Y : particularly relevant if combined with another 

document of the same category 
A : technological background 
O : non-written disclosure 
P : intermediate document 



T : theory or princes underlying the invention 
E : eariier patent document, but published on, or 

after the tiling date 
D : document cited in the application 
L : document cited for other reasons 



& : member of the same patent famBy, corresponding 
document 



Patent nrnvirtarl hv Si inhn ip Minn PI I P. - httn-//www si mhn i« rnm 



